





12.24196

### Introduction to Embedded Systems

Prof. Dr.-Ing. Stefan Kowalewski | Julius Kahle, M. Sc. Summer Semester 2025

Part 3

Programmable Logic Controllers

### Content

- Logic Control
- 2. PLC Technology
- 3. Programming languages
  - Function Block Diagram (FBD)
  - Ladder Diagram (LD)
  - Instruction List
- 4. Model-based Design
- 5. Sequential Controllers
  - Sequential Function Charts





### Logic Control vs. Continuous Control (1)

- Introduction by examples
- Example 1: A Trip (Abschaltung, Notabschaltung)
- Representation:
   Piping and Instrumentation
   Diagram (P&ID, ISO 3511)
- A P&ID shows all major plant equipment like pipes, tanks, valves, and the main control functions
- Function of the trip: Switch off heating, when temp has reached a certain value.
- Purpose: Avoid undesired (e.g. dangerous) process states









### Logic Control vs. Continuous Control (2)

- Example 2: An Interlock (Verriegelung)
- Function of the interlock: Enable only desired operator action (disable undesired ones).
- Purpose:

   Avoid undesired process
   states caused by
   undesired operator actions.







### Logic Control vs. Continuous Control (3)

Example 3: A Sequence Controller (Ablaufsteuerung)

Function of a sequence controller:

Realize a desired sequence

of process steps.

- Here:
  - 1. Fill tank (open V1 until LIS+)
  - 2. Heat up (open V2 until TIS+)
  - 3. Drain tank (open V3 until LIS\_)







### Logic Control vs. Continuous Control (3)

Example 3: A Sequence Controller (Ablaufsteuerung)

Function of a sequence controller:
Realize a desired sequence
of process steps.

- Here:
  - 1. Fill tank (open V1 until LIS+)
  - 2. Heat up (open for m minutes)
  - 3. Drain tank (open for n minutes)







### **Logic Control vs. Continuous Control (4)**

Example 4: A Continuous Controller

Function of a continuous controller: Keep process variable at a desired value (despite disturbances or in case of changes of the settings).







### **Logic Control vs. Continuous Control (5)**

General Control Structure (for all three examples)







### **Logic Control vs. Continuous Control (6)**

- Main difference between logic (trip, interlock, sequence controller) and continuous control?
- The main purpose of logic controllers is the processing of discrete variables
- Example: Trip

```
Logic Control:
```

```
temp(t) ∈ { below_limit, above_limit}
```

**Continuous Control:** 

```
temp(t) \subset \mathbb{R} \times \{^{\circ}C\}
```





### Logic Control vs. Continuous Control (6)







## **Logic Control vs. Continuous Control (7)**

heating(t)  $\in$  { on, off, broken, inrepair}



▶ Difference?





### Content

- Logic Control
- 2. PLC Technology
- 3. Programming languages
  - Function Block Diagram (FBD)
  - Ladder Diagram (LD)
  - Instruction List
- 4. Model-based Design
- 5. Sequential Controllers
  - Sequential Function Charts





### **Programmable Logic Controllers (1)**

### **Device platforms for implementing logic controllers:**

- Dedicated hardware ("hardwired logic")
  - German: Verbindungsprogrammierte Steuerung (VPS)
- Programmable Logic Controllers (PLC)
  - German: Speicherprogrammierbare Steuerung (SPS)
- Distributed Control Systems (DCS)
  - Prozessleitsysteme (PLS)
- Industrial PCs (IPCs)
- Soft-PLCs





## **Programmable Logic Controllers (2)**

### **Examples**



© Hitachi, http://www.hitachi-ies.co.jp/english/products/plc/eh\_150/product\_range.htm





### **Programmable Logic Controllers (3)**

### **Examples**





© plcs.net, <a href="http://www.plcs.net/chapters/whatis1.htm">http://www.geometrixar.com/plc\_programming</a>





# **Programmable Logic Controllers (4)**

# **Examples**





© Degensha, http://www.dengensha.com/site.cfm/nut-feeders.cfm





# **Programmable Logic Controllers (5)**

**Examples** 



© DirectIndustry, <a href="http://img.directindustry.com/images\_di/photo-g/programmable-logic-controller-plc-359905.jpg">http://img.directindustry.com/images\_di/photo-g/programmable-logic-controller-plc-359905.jpg</a>,

http://www.walkeremd.com/Eaton-Cutler-Hammer-PLC1.htm





# **Programmable Logic Controllers (6)**

Examples SIMATIC









64-500

© https://engineering.purdue.edu/ManLab/plc.html, http://www.pacontrol.com/siemens-plc-training.html,





# **Programmable Logic Controllers (7)**

# **Examples**



© http://www.hinrichsen-haustechnik.de/grafik/sps2.jpg





## **Programmable Logic Controllers (8)**

# Pyramid model of industrial automation

### Layers:



#### Functions:

### Higher Functions:

advanced continuous control recipe control alarm handling/registration visualization displaying/operating

#### Basic functions:

basic continuous control sequence control threshold supervision safety trips interlocks

local displays local manual operating sensing actuating





### **Programmable Logic Controllers (9)**

### **PLC** architecture



PAA= Prozessabbild der Ausgänge





### **Programmable Logic Controllers (10)**

PLC operating system: Cyclic Scanning Mode





### **Programmable Logic Controllers (10)**

PLC operating system: Cyclic Scanning Mode



One turn around = cycle (≈ ms)





# **Programmable Logic Controllers (11)**

Execution of cyclic scans in the PLC architecture:







### **Programmable Logic Controllers (12)**

The cycle time can vary depending on the program execution.

**Example:** 

```
IF input=TRUE THEN GOTO END ELSE
.
. (many instructions)
.
END: END_IF
```

- Example: Program with one integer variable i, initially i:= 0.
- i:=i+1:
  - "normal" computer after execution i=1.
  - PLC: after first cycle i=1.
  - after second cycle i=2 ...





### **Programmable Logic Controllers (13)**

Maximal reaction time (delay between process event and corresponding control action)?

worst case: 2x max. cycle time P change written in input memory input change output (process event) change (control reaction)





### **Programmable Logic Controllers (14)**

- Maximal reaction time = 2 \* maximal cycle time
- Cyclic scanning mode supports estimation of real-time behavior:
  - Determine longest program execution path.
  - Measure or estimate cycle time for this execution path.
  - Apply formula above.
- ▶ What to do, if reaction time is too long?
  - Optimize Program
  - Choose more performant PLC
  - Use interrupts





### Content

- Logic Control
- 2. PLC Technology
- 3. Programming languages
  - Function Block Diagram (FBD)
  - Ladder Diagram (LD)
  - Instruction List
- 4. Model-based Design
- 5. Sequential Controllers
  - Sequential Function Charts





### **PLC programming languages**

### ► Before 1992:

- "Similar" PLC languages
- either resembling electrical design or assembly
- Each PLC vendor used its own dialect
- Disadvantages?
- ➤ 1992: IEC 61131 International standardization of five PLC languages

| Abbreviation | Name                                       | German Name           |
|--------------|--------------------------------------------|-----------------------|
| FB           | Function Block                             | Funktionsblocksprache |
| LD           | Ladder Diagram<br>Relay Ladder Logic (RLL) | Kontaktplan           |
| IL           | Instruction List                           | Anweisungsliste       |
| ST           | Structured Text                            | Strukturierter Text   |
| SFC          | Sequential Function Charts                 | Ablaufsprache         |





### ► Idea:

- Resembling switching circuit design by gates
- blocks with input and output







► Basic logic operators:







### **Example:**







▶ Blocks are not restricted to logic operators.

### NAND, ADD, MULT, TIMER









# IEC 61131 languages: Ladder Diagram (LD)

# Kontakt polan (KOP)

### ► Idea:

Resembling switching circuit design by relays ("schematics")

"contacts" and "coils"





### IEC 61131 languages: Ladder Diagram (LD)

### ► Idea:

- Resembling switching circuit design by relays ("schematics")
- "contacts" and "coils"







## IEC 61131 languages: Ladder Diagram (LD)

► Basic logic operators:









# IEC 61131 languages: Ladder Diagram (LD)

► Basic logic operators:









# **IEC 61131 languages: Ladder Diagram (LD)**

## **Example:**







# IEC 61131 languages: Ladder Diagram (LD)

► Function blocks can be integrated into LD programs:





#### **IEC 61131: Functions vs. Function Blocks**



Example of a "Function Block":





## **IEC 61131 Standard Function Blocks: Latches (1)**

- ► How can the desired functionality be programmed using only the already known basic operators?
  - FB:









# **IEC 61131 Standard Function Blocks: Latches (2)**

Switching off the motor?

• FB:

Off

Off

Notor

AND

LD:







## **IEC 61131 Standard Function Blocks: Bistables (1)**

► Combination of both latches: motor motor **AND** On **OR** motor OR **AND** motor.





#### IEC 61131 Standard Function Blocks: Bistables ctd.

Bistable as standard Function Block:







### IEC 61131 Standard Function Blocks: Bistables ctd.







# **IEC 61131 Standard Function Blocks: Edge Triggers**

Flanzeneszenne

- ▶ Problem: A change of a variable shall be detected or indicated.
- Example:



Desired function:







# IEC 61131 Standard Function Blocks: Edge Triggers (ctd.)







#### **IEC 61131 Standard Function Blocks: Timers**

- ▶ IEC 61131 defines three different timer function blocks:
  - TON Timer On Delay
  - TOF Timer Off Delay
  - TP Timer Pulse







# **IEC 61131 Standard Function Blocks: Timers (ctd.)**

Timing diagram for TON: Eiushalt veriges







# **IEC 61131 Standard Function Blocks: Timers (ctd.)**

Timing diagram for TOF:







# **IEC 61131 Standard Function Blocks: Timers (ctd.)**

► Timing diagram for TP:







**Anweisungsliste (AWL)** 

- Textual programming language ("list of instructions")
- ~ Assembly language
- Instruction syntax:

| (label:) | operator | operand |
|----------|----------|---------|
| e.g. END | AND      | sensor1 |

One-register or accumulator architecture

**Aktuelles Ergebnis (AE)** 

Accumulator is called CR ("current result")





► Basic operators: lusbouching

LD X "Load" 
$$CR = X$$

AND X

 $CR \longrightarrow AND \longrightarrow CR$ 
 $CR := CR \land X$ 
 $CR \longrightarrow CR := CR \land X$ 
 $CR \longrightarrow CR \longrightarrow CR$ 
 $CR \longrightarrow CR := CR \lor X$ 

Also: XOR (exclusive OR)





Basic operators with negation:





Basic operators: Math instructions

GT 
$$X$$
 "Greater-than"  $CR := \begin{cases} 1 \text{ if } CR > X \\ 0 \text{ else} \end{cases}$ 

$$EQ \quad X \quad \text{"Equal"} \quad CR := \begin{cases} 1 \text{ if } CR > X \\ 0 \text{ else} \end{cases}$$

MOD X

"Modulo"

CR:= CR mod X

Also: LT, GE & LE (Less or Equal), NE (Not Equal), ADD, SUB, MUL, DIV





Basic operators (ctd.):

ST

X

"Store"

X := CR

S

X

'Set"

 $X:=\begin{cases} 1 & \text{if } CR=1\\ X & \text{if } CR=0 \end{cases}$ 

R

X

"Reset"

 $X:= \begin{cases} \underline{0 \text{ if } CR=1} \\ X \text{ if } CR=0 \end{cases}$ 





Basic operators (ctd.): GOTO instructions

JMP label "jump"

JMPC label "jump conditionally"

Go to label if CR=1

JMPCN label "jump conditionally negated"

Go to label if CR=0

Also: RET/RETC/RETCN (Return, i.e. jump to the end of the program)





Basic logic operations in IL: そに メルフ



declaration of variables



ightharpoonup Example:  $f := a \land (b \lor \neg c)$ 

| LD  | b | LD   | a |
|-----|---|------|---|
| ORN | С | AND( | b |
| AND | а | ORN  | С |
| ST  | f | )    |   |
|     |   | ST   | f |



# **IEC 61131 languages: Instruction List – Example**

| (* Methode 1 *)                                                                               | (* Methode 2 *)                                                           | (* Methode 3 *)                   |
|-----------------------------------------------------------------------------------------------|---------------------------------------------------------------------------|-----------------------------------|
| (* Parameterversorgung: *)  Free fin a Aus  +#500ms-PT ET Dest                                | LD t#500ms<br>ST Zeit1.PT<br>LD Frei<br>ST Zeit1.IN                       | LD t#500ms<br>PT Zeit1<br>LD Frei |
| (* Aufruf: *) CAL Zeit1( IN:=Frei, PT:=t#500ms, Q=>Aus, (*Ausgangsp*) ET=>Wert(*Ausgangsp*) ) | CAL Zeit1                                                                 | IN Zeit1                          |
|                                                                                               | (* Auswertung der Ausgangsparam. *) LD Zeit1.Q ST Aus LD Zeit1.ET ST Wert |                                   |

[Source: John & Tiegelkamp: SPS-Programmierung mit IEC 61131-3, Springer-Verlag, 4. Aufl., S. 115]





Bistables?





Function block calls in IL: Example RS



#### Variant 1:

ST myBistable.S

LD y

ST myBistable.R

...

CAL myBistable

Z

#### Variant 2:

CAL myBistable(S:=x,R:=y)
LD myBistable.Q
ST Z





myBistable.Q

LD

ST

Function block calls in IL: Example TON

```
VAR
myTimer:TON;
start,motor:BOOL;
END_VAR
```

```
LD start
ST myTimer.IN
CAL myTimer(PT:= T#1min30s)
...
LD myTimer.Q
S motor
```





## **Content**

- Logic Control
- 2. PLC Technology
- 3. Programming languages
  - Function Block Diagram (FBD)
  - Ladder Diagram (LD)
  - Instruction List
- 4. Model-based Design
- 5. Sequential Controllers
  - Sequential Function Charts











- Problems with this approach:
- 1. Does the specification represent the originally desired behavior?
- 2. Is the specification complete and consistent
- 3. How to implement the specification?

- Instead: Build a model of the controller first.
- 1. It helps discussing/clarifying the specification.
- 2. It can be analyzed algorithmically.
- 3. Automatic code generation becomes possible.





Our model: Moore and Mealy automata.

$$A = (X, U, Y, f, g, x_0)$$

X: Set of discrete states

*U*: input alphabet

Y: output alphabet

 $f: X \times U \rightarrow X$ 

g: output function

 $x_0$ : initial state

state trans. fct.:

$$x'=f(x,u)$$

#### **Moore Automaton:**



### Mealy Automaton:







Our example for model-based design: A function block for alarm handling



### Specification:

- The RED light must be switched on as soon as DANGER becomes TRUE.
- 2. When the operator presses the RECEIPT button, the RED light is switched off and the YELLOW light is switched on.
- 3. When the danger is over, the YELLOW light can be switched off by pressing the RESET button.





# Modeling the example

1. Variables, type of automata

$$x = (red, yellow) \in \{(0,0), (1,0), (0,1)\}$$

$$u = (danger, receipt, reset) \in \mathbb{B}^3$$

$$y = x$$









Code generation: Your suggestions?





Code generation

Systematic approach: Divide program into two parts:

- Check and perform transitions
- 2. Set or reset output





# Model-based development of logic control programs (ctd.)

Code Generation, Solution: Variable declarations

```
VAR INPUT
 danger,receipt,reset:BOOL;
END VAR
VAR OUTPUT
 red,yellow:BOOL;
END_VAR
VAR
 X0:BOOL:=TRUE;
 X1,X2:BOOL:=FALSE;
END VAR
```





# Model-based development of logic control programs (ctd.)

# Code Generation, Solution: Check and perform transitions

```
LD x0
    AND danger CR:= 0
STU R XO 1
JPMC output
    LD x1
    AND receipt
57 R x1
ST S x2
    JPMC output
    LD x2
    ANDN danger
    AND reset
57W R x2
57 5 x0
```





# Model-based development of logic control programs (ctd.)

## Code Generation, Solution: **Set/reset outputs**

output: LD x0

R yellow

R red

LD x1

S red

R yellow

LD x2

R red

S yellow





## **Content**

- Logic Control
- 2. PLC Technology
- 3. Programming languages
  - Function Block Diagram (FBD)
  - Ladder Diagram (LD)
  - Instruction List
- 4. Model-based Design
- 5. Sequential Controllers
  - Sequential Function Charts

**LFC** 

Verreelen somme

Montsprade 45





# **Specification and Implementation of Sequence Controllers**

Example: A dosing and heating unit feed **V1** LIS+ dosing tank T1 LIS **V2** heating tank T2 TIS+ **V3 V4** 





# **Specification and Implementation of Sequence Controllers**

## Process specification for the example

|          |  | Steps                 | <b>Control Actions</b> | <b>Transition Conditions</b> |
|----------|--|-----------------------|------------------------|------------------------------|
| sedneuce |  | 1.) Fill T1           | by opening V1          | Until LIS1 activated         |
|          |  | 2.) Fill T2           | by opening V2          | Until LIS2 activated         |
|          |  | 3.) Heat T2           | by opening V3          | Until TIS3 activated         |
|          |  | 4.) Empty T2          | by opening V4          | Until T2 is empty            |
|          |  | 5.) go back to step 1 |                        |                              |





# **Specification and Implementation of Sequence Controllers**

#### Consequence:

 A specification and programming language for sequence controllers must be able to represent all these elements (steps, actions, transitions, conditions, sequences, parallelism).

→ Sequential Function Chart (SFC)





## 1. Steps:







#### 2. Actions:









#### 3. Transitions:







## 4. Connections:







## 5. Branching and joining:

- Alternative
  - Start & End branch with Transitions





- Parallel
  - Start & End branch with Steps









## Firing rule:

A transition of a SFC fires, if

- all preceding steps are active, and
- all succeeding steps are inactive, and
- the transition condition is true.

Strong firing rule<br/>Weak firing rule

When a transition fires, all preceding steps become inactive and all succeeding steps become active.



Firing rule (ctd.)

If more than one transition can fire, priority rules apply.

Example:











## Embedding of the SFC execution into the PLC scanning cycle:

- 1. (Read inputs.)
- 2. Execute actions or underlying programs for the active steps.
- Determine transitions which can fire.
- 4. Fire transitions.
- (Write outputs.)

## Example:









# **Dosing and heating tank**







# SFC for the dosing and heating tank







# SFC for the dosing and heating tank







# SFC for the dosing and heating tank (complete view)





